# Lab 1 Report - 8-bit Simple ALU

#### Lab 1 Report - 8-bit Simple ALU

Lab Targets

Circuit Diagram

Steps to Generate Circuit Diagram

Diagram

Code and Comments

ALU - Lab1.v

Testbench and Wave

Testbench - Lab1.vt

Wave

Resource Allocation

Summary

#### **Source Code**

ALU - Lab1.v

ALU Test Bench

## **Lab Targets**

Design an 8-bit Arithmetic Logical Unit (ALU), based on the method of top-down module system design.

The functions are shown in the table, and eight operations such as addition, subtraction, logical AND, and OR are implemented according to the operation code.

The input operand is an 8421 code combination corresponding to a four-digit number starting from the end of the student number.

| Operand  | Function          |
|----------|-------------------|
| Add      | a+b               |
| Subtract | a-b               |
| Or_AB    | $a\mid b$         |
| And_AB   | $a \ \& \ b$      |
| Not A    | $\sim a$          |
| Exor     | $a \wedge b$      |
| Exnor    | $a \sim \wedge b$ |
| Ror_A    | $\mid a$          |

# **Circuit Diagram**

### **Steps to Generate Circuit Diagram**

Step1: Processing > start > Analysis & Elaboration

Step2: Tools > Netlist viewer > RTL viewer

### **Diagram**



## **Code and Comments**

#### ALU - Lab1.v

```
1
    module Lab1(output reg [7:0] ALU_out, input [7:0] Data_A, Data_B, input [2:0] Opcode);
       parameter Add = 3'b000, // A + B
2
                             = 3'b001, // A - B
3
                   Subtract
                           = 3'b010, // A | B
                   Or_AB
4
                   And_AB
                             = 3'b011, // A \& B
5
                              = 3'b100, // ~ A
                   Not_A
6
                              = 3'b101, // A^B
7
                   Exor
                              = 3'b110, // A \sim ^B
8
                   Exnor
9
                   Ror_A
                              = 3'b111; // | A
10
       always@(*)
11
12
13
       case(Opcode)
           Add:
                      ALU_out = Data_A + Data_B;
14
           Subtract: ALU_out = Data_A - Data_B;
15
                      ALU_out = Data_A | Data_B;
           Or_AB:
16
17
           And_AB:
                     ALU_out = Data_A & Data_B;
           Not_A:
                      ALU_out = ~ Data_A;
18
                      ALU_out = Data_A ^ Data_B;
19
           Exor:
                      ALU_out = Data_A ~^ Data_B;
20
           Exnor:
21
           Ror A:
                      ALU out <= {Data A[0],Data A[7:1]};
       endcase
22
23
    endmodule
```

This model named Lab1, has one input port and three output ports. Which are

- 1. ALU\_out: A 8-bit output, which is result of number after ALU process.
- 2. Data\_A: A 8-bit input, the first data be sent to ALU.
- 3. Data\_B: A 8-bit input, the second data be sent to ALU.
- 4. Opcode: A 3-bit input, to control the ALU function.

We declare 8 parameters for identifying 8 operations respectively. The details are described in the following table.

| Operation | Function   | Opcode | Operation | Function          | Opcode |
|-----------|------------|--------|-----------|-------------------|--------|
| Add       | a+b        | 000    | Not A     | $\sim a$          | 100    |
| Subtract  | a-b        | 001    | Exor      | $a \wedge b$      | 101    |
| Or_AB     | $a \mid b$ | 010    | Exnor     | $a \sim \wedge b$ | 110    |
| And_AB    | a & b      | 011    | Ror_A     | a                 | 111    |

In line 11, always@(\*) statement always here to tell that the following codes always run.

Start at line 13 is case statement, which is used to define the functions of each operation in details.

## **Testbench and Wave**

#### Testbench - Lab1.vt

```
module Lab1_vlg_tst();
    // test vector input registers
 2
    reg [7:0] Data_A;
 3
    reg [7:0] Data_B;
    reg [2:0] Opcode;
 5
    // wires
 6
    wire [7:0] ALU_out;
 8
 9
    // assign statements (if any)
10
11
    // port map - connection between master ports and signals/registers
12
        .ALU_out(ALU_out),
13
        .Data_A(Data_A),
       .Data_B(Data_B),
14
        .Opcode(Opcode)
15
    );
16
17
    initial
    begin
18
19
    // code that executes only once
    // insert code here --> begin
20
21
        Data_A = 8'b00100011;
        Data_B = 8'b00111000;
22
23
        #20 Opcode = 3'b000;
24
25
        #20 Opcode = 3'b001;
26
        #20 Opcode = 3'b010;
        #20 Opcode = 3'b011;
2.7
        #20 Opcode = 3'b100;
2.8
        #20 Opcode = 3'b101;
2.9
        #20 Opcode = 3'b110;
30
        #20 Opcode = 3'b111;
31
32
    // --> end
    $display("Running testbench");
34
    endmodule
```

From *Experiments Handbook of Digital System Design* we know that the input operand is an 8421 code combination corresponding to a four-digit number starting from the end of the student number.

In this testbench, we use Student Number is 16206553, so the input number are  $35_{10}$  and  $56_{10}$ 

$$35_{10} = 00100011_2$$
$$56_{10} = 00111000_2$$

Then, we tested each opcode evey 20 ps.

### Wave



We can seen the output result are we expected.

## **Resource Allocation**

Shi Bo: All the Lab 1 is finished by Shi Bo.

## **Summary**

In this Lab, out team design a simple 8-bit ALU. Each of us participated in the experiment, completed the experiment together, and performed a simulation test. We successfully completed this experiment and the results are satisfactory.

## **Source Code**

### ALU - Lab1.v

```
1
    module Lab1(output reg [7:0] ALU_out, input [7:0] Data_A, Data_B, input [2:0] Opcode);
2
        parameter
                            = 3'b000, // A + B
                                    = 3'b001,
                        Subtract
                                                // A - B
                        Or_AB
                                    = 3'b010,
                                               // A | B
4
                        And_AB = 3'b011, // A & B
5
                                    = 3'b100,
                        Not A
                                                // ~ A
6
                                    = 3'b101,
                                                // A ^ B
                        Exor
                                    = 3'b110, // A ~ ^{\circ} B
                        Exnor
8
                                    = 3'b111; // | A
                        Ror_A
9
10
11
        always@(*)
12
13
        case(Opcode)
            Add:
                            ALU_out = Data_A + Data_B;
15
            Subtract:
                        ALU_out = Data_A - Data_B;
            Or AB:
                        ALU_out = Data_A | Data_B;
16
17
            And_AB:
                        ALU_out = Data_A & Data_B;
            Not_A:
                        ALU_out = ~ Data_A;
18
            Exor:
                            ALU_out = Data_A ^ Data_B;
19
20
            Exnor:
                        ALU_out = Data_A ~^ Data_B;
21
            Ror_A:
                        ALU_out <= {Data_A[0],Data_A[7:1]};</pre>
22
        endcase
23
    endmodule
```

## **ALU Test Bench**

```
// Copyright (C) 2018 Intel Corporation. All rights reserved.
   // Your use of Intel Corporation's design tools, logic functions
   // and other software and tools, and its AMPP partner logic
   // functions, and any output files from any of the foregoing
   // (including device programming or simulation files), and any
5
   // associated documentation or information are expressly subject
6
   // to the terms and conditions of the Intel Program License
   // Subscription Agreement, the Intel Quartus Prime License Agreement,
   // the Intel FPGA IP License Agreement, or other applicable license
   // agreement, including, without limitation, that your use is for
11
   // the sole purpose of programming logic devices manufactured by
   // Intel and sold by Intel or its authorized distributors. Please
12
1.3
   // refer to the applicable agreement for further details.
14
15
   // This file contains a Verilog test bench template that is freely editable to
16
   // suit user's needs .Comments are provided in each section to help the user
17
18
   // fill out necessary details.
   // Generated on "10/25/2019 18:04:54"
20
   // Verilog Test Bench template for design : Lab1
23
24
   // Simulation tool : ModelSim-Altera (Verilog)
25
26
   // My UCD Student Number is 16206553
27
28
   // The input number are 35d and 56d.
   // 0010 0011b and 0011 1000b.
29
   30
31
   `timescale 1 ps/ 1 ps
32
   module Lab1 vlg tst();
34
   // constants
35
   // general purpose registers
36
   reg eachvec;
   // test vector input registers
37
   reg [7:0] Data_A;
38
39
   reg [7:0] Data_B;
   reg [2:0] Opcode;
40
   // wires
41
   wire [7:0] ALU out;
42.
43
44
   // assign statements (if any)
   Lab1 i1 (
   // port map - connection between master ports and signals/registers
46
47
       .ALU_out(ALU_out),
48
      .Data_A(Data_A),
49
       .Data B(Data B),
50
       .Opcode(Opcode)
   );
51
```

```
initial
52
    begin
    // code that executes only once
55
    // insert code here --> begin
56
       Data_A = 8'b00100011;
57
       Data_B = 8'b00111000;
58
        #20 Opcode = 3'b000;
59
       #20 Opcode = 3'b001;
60
        #20 Opcode = 3'b010;
61
        #20 Opcode = 3'b011;
62
       #20 Opcode = 3'b100;
63
        #20 Opcode = 3'b101;
64
65
        #20 Opcode = 3'b110;
        #20 Opcode = 3'b111;
67
    // --> end
    $display("Running testbench");
69
    end
70
    always
71
    // optional sensitivity list
72
    // @(event1 or event2 or .... eventn)
73
    begin
74
    \ensuremath{//} code executes for every event on sensitivity list
    // insert code here --> begin
75
76
77
    @eachvec;
    // --> end
78
    end
    endmodule
81
```